AMENDMENTS TO THE CLAIMS 



This listing of claims will replace all prior versions, and listings, of claims 
in the application: 

Listing of Claims: 

1. (Currently amended) A method for executing a fail instruction to 
facilitate transactional execution on a processor, comprising: 

executing a start transactional execution instruction to start transactionally 
executing a block of instructions within a program; 

wherein changes made during the transactional execution are not 
committed to the architectural state of the processor unless the transactional 
execution successfully completes; and 

if the fail instruction is encountered during the transactional execution, 

terminating the transactional execution without committing 
results of the transactional execution to the architectural state of 
the processor, wherein t e rminatmg th e tran s actional execution 
involv e s branching to a location sp e cifi e d by th e fail instruction 

retrying the transactional execution a specified number of 
times, and 

if the fail instruction continues to be encountered, obtaining 
a lock for the block of instructions . 

2. (Original) The method of claim 1, wherein terminating the transactional 
execution involves discarding changes made during the transactional execution. 
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1 3. (Original) The method of claim 2, wherein discarding changes made 

2 during the transactional execution involves: 

3 discarding register file changes made during the transactional execution; 

4 clearing load marks from cache lines; 

5 draining store buffer entries generated during transactional execution; and 

6 clearing store marks from cache lines. 

1 4. (Original) The method of claim 1, wherein terminating the transactional 

2 execution additionally involves branching to a location specified by a 

3 corresponding start transactional execution (STE) instruction. 

1 5 (Canceled) 

1 6. (Original) The method of claim 1, wherein terminating the transactional 

2 execution additionally involves attempting to re-execute the block of instructions. 

1 7. (Original) The method of claim 1, wherein if the transactional execution 

2 of the block of instructions is successfully completes, the method fiirther 

3 comprises: 

4 atomically committing changes made during the transactional execution; 

5 and 

6 resuming normal non-transactional execution. 

1 8. (Original) The method of claim 1 , wherein potentially interfering data 

2 accesses from other processes are allowed to proceed during the transactional 

3 execution of the block of instructions. 
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1 9. (Original) The method of claim 1, wherein if an interfering data access 

2 from another process is encountered during the transactional execution, the 

3 method further comprises: 

4 discarding changes made during the transactional execution; and 

5 attempting to re-execute the block of instructions. 

1 10. (Original) The method of claim 1, wherein the block of instructions to 

2 be executed transactionally comprises a critical section. 

1 11. (Original) The method of claim 1 , wherein the fail instruction is a 

2 native machine code instruction of the processor. 

1 12. (Original) The method of claim 1, wherein the fail instruction is 

2 defined in a platform-independent programming language. 

1 13. (Currently amended) A computer system that supports a fail instruction 

2 to facilitate transactional execution, comprising: 

3 a processor; and 

4 an execution mechanism within the processor; 

5 wherein the execution mechanism is configured to execute a start 

6 transactional execution instruction to transactionally execute a block of 

7 instructions within a program; 

8 wherein changes made during the transactional execution are not 

9 committed to the architectural state of the processor unless the transactional 

10 execution successfully completes; and 

1 1 wherein if the fail instruction is encountered during the transactional 

12 execution, the execution mechanism is configured toi 
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1 3 I terminate the transactional execution without committing 

14 results of the transactional execution to the architectural state of 

1 5 the processor, wh e r e in teminating th e transactional e x e cution 

16 involv e s branching to a location sp e cified by the fail instruction 

17 retry the transactional execution a specified number of 

18 times, and 

19 if the fail instruction continues to be encountered, obtain a 

20 lock for the block of instmctions . 

1 14. (Original) The computer system of claim 13, wherein while 

2 terminating the transactional execution, the execution mechanism is configured to 

3 discard changes made during the transactional execution. 

1 15. (Original) The computer system of claim 14, wherein while discarding 

2 changes made during the transactional execution, the execution mechanism is 

3 configured to: 

4 discard register file changes made during the transactional execution; 

5 clear load marks fi-om cache lines; 

6 drain store buffer entries generated during transactional execution; and to 

7 clear store marks from cache lines. 

1 16. (Original) The computer system of claim 13, wherein while 

2 terminating the transactional execution, the execution mechanism is additionally 

3 configured to branch to a location specified by a corresponding start transactional 

4 execution (STE) instruction. 

1 17 (Canceled). 
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1 18. (Original) The computer system of claim 13, wherein while 

2 terminating the transactional execution, the execution mechanism is additionally 

3 configured to attempt to re-execute the block of instructions. 

1 19. (Original) The computer system of claim 13, wherein if the 

2 transactional execution of the block of instructions is successfully completes, the 

3 execution mechanism is configured to: 

4 atomically commit changes made during the transactional execution; and 

5 to 

6 resume normal non-transactional execution. 

1 20. (Original) The computer system of claim 13, wherein the computer 

2 system is configured to allow potentially interfering data accesses from other 

3 processes to proceed during the transactional execution of the block of 

4 instructions. 

1 21. (Original) The computer system of claim 13, wherein if an interfering 

2 data access fi'om another process is encountered during the transactional 

3 execution, the execution mechanism is configured to: 

4 discard changes made during the transactional execution; and to 

5 attempt to re-execute the block of instructions. 

1 22. (Original) The computer system of claim 13, wherein the block of 

2 instructions to be executed transactionally comprises a critical section. 

1 23. (Original) The computer system of claim 13, wherein the fail 

2 instruction is a native machine code instruction of the processor. 
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24. (Original) The computer system of claim 13, wherein the fail 
instruction is defined in a platform-independent programming language. 

25. (Currently amended) A computing means that supports that supports a 
fail instruction to facilitate transactional execution, comprising: 

a processing means; and 

an execution means within the processing means; 

wherein the execution means is configured to execute a start transactional 
execution instruction to transactionally execute a block of instructions within a 
program; 

wherein changes made during the transactional execution are not 
committed to the architectural state of the processor unless the transactional 
execution successfully completes; and 

wherein if the fail instruction is encountered during the transactional 
execution, the execution means is configured toi 

terminate the transactional execution without committing 
results of the transactional execution to the architectural state of 
the processor, wherein terminating the transactional execution 
involves branching to a location sp e cifi e d by th e fail instruction 

Yctiy the ti'ansactional execution a specified number of 
times, and 

if the fail instruction continues to be encountered, obtain a 
lock for the block of instructions. 
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